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PATENT 

ATTORNEY DOCKET NO: 10559/055001/P74 04 

BROADCASTING AND PROCESSING MULTIPLE DATA FORMATS 
Background of the Invention 
5 This invention relates to broadcasting and processing 

data . 

Some digital televisions use a viewer application to 
process data from an audio or video broadcast. The viewer 
application decodes and presents homogeneous data from 
different content providers for listening or viewing. 
5 Recently, several new content formats have been 

developed for data broadcasts. These new contents combine 
video data and with other content data that enables 
interactive viewing. New types of software viewer 
applications process the new content formats. 
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Summary of the Invention 
In a first aspect, the invention provides a method of 
broadcasting data. The method includes sending to a receiver 
scheduling information that includes a scheduled time and 
15 broadcasting data at the scheduled time. The scheduling 
information identifies one or more viewer applications 
capable of processing the broadcast data. 

In a second aspect, the invention provides a method 
of processing data. The method includes receiving scheduling 
20 information that provides broadcast times for data broadcasts 
and information to identify viewer applications to process 
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the data broadcasts. The method also includes receiving data 
from one of the broadcasts at the scheduled broadcast time 
and processing the received data with a viewer application 
responsive to the scheduling information. 
5 In a third aspect, the invention provides a method of 

processing data. The method includes receiving scheduling 
information that provides broadcast times for data broadcasts 
and information for identifying viewer applications for 
processing the broadcasts. The method also includes writing 

10 the scheduling information to a scheduling table having 
entries indexed by scheduled broadcast times and channels. 

In a fourth aspect, the invention provides a method of 
processing data. The method includes receiving data from a 
broadcast at a scheduled broadcast time and selecting a 

15 viewer application from a table of available viewer 

applications to process the data. The method also includes 
processing the received data with the selected viewer 
application. 

Other features and advantages of the invention will be 
20 apparent from the following description and claims. 

Brief Description of the Drawings 
FIG. 1 illustrates a network for broadcasting data in 
accordance with an embodiment of the invention; 
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FIG. 2 illustrates a device for viewing data broadcast 
on the network of FIG. 1 in accordance with an embodiment of 
the invention; 

FIG. 3 is a flow chart, illustrating a method of 
processing broadcasted data in accordance with an embodiment 
of the invention; 

FIG. 4 shows a portion of an exemplary scheduling table 
in accordance with an embodiment of the invention; 

FIG. 5 shows a portion of an exemplary viewer 
application selection table in accordance with an embodiment 
of the invention; and 

FIG. 6 is a flow chart illustrating a method of 
broadcasting data in accordance with an embodiment of the 
invention. 

Detailed Description 

FIG. 1 illustrates a network 10 for broadcasting data 
from transmitters 11-13 to receivers 15-18. The transmitters 
11-13 dynamically change the content format of the data in 
successive broadcasts. The receivers 15-18 dynamically 
adjust to process the different content formats differently. 

Each receiver 15-18 includes a television with a 
programmable processor or a personal computer for presenting 
the broadcasts to viewers. The receivers 15-18 are 



10559/055001/P7404 
dynamically reprogrammable to process data from different 
broadcasts differently. 

The transmitters 11-13 broadcast the data through a 
transport medium 20, such as the Internet, i.e., in multicast 
group broadcasting, a cable network, a wireless network, a 
satellite network,. an Advanced Television Systems Committee 
(ATSC) network. The medium 20 has separate broadcast 
channels on which different transmitters 11-13 may broadcast. 
A viewer tunes his receiver 15-18 to one of the channels to 
receive data from the transmitter 11-13 using that channel. 

The transmitters 11-13 broadcast data in a digital 
coded format. The broadcast data is received and processed 
by the receivers 15-18. The processing includes decoding the 
data and presenting the decoded data for audio listening or 
video viewing. Each receiver 15-18 can process several 
content formats of broadcast data. 

The data of each broadcast belongs to one content 
format, but the broadcasts can have any format. The content 
formats may conform to standards and may contain additional 



features specific to particular content providers. The 
standards include the MPEG-2 standard^^^^^ublished in ISO/IEC 
directives 13818-1 to 13818-3, approved Nov. 1994; the 
standard proposed in ATVEF comment Draft Specification 
version 1.1, published by the Advanced TV Enhancement Forum 
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in July 1998; or another standard for coding video or audio 

data. The features specific to particular providers are 

enhancements to standard formats, e.g., Disney ATVEF format. 

The enhancements enable individual content providers to 

5 exercise control over processing performed by the receivers 

15-18 as described below. 

FIG. 2 shows the receiver 15 of FIG. 1 embodied in a 

personal computer 15'. The personal computer 15' has a 

microprocessor 21 that can use several viewer applications 

\/iou line. u/hicl^ C&nhe^ohS fQ 

10 23-25 to process broadcast data ^ received^j^^rofl* network 

5^ interface 22. The viewer applications 23-25 are stored in a 
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writable data storage device 26, e.g., a hard disk or random 
access memory (RAM) . The viewer applications 23-25 enable 
the microprocessor 21 to decode the broadcast data received 

15 from the interface 22 and to present the decoded data on 
listening and visual viewing devices 29, 30, 

The microprocessor 21 executes a control application 
19 that selects an appropriate viewer application 23-25 to 
process data from each broadcast. The control application 19 

20 uses a scheduling table 31 and a viewer application selection 
table 32 to select one of the viewer applications 23-25 for 
processing data from each broadcast. The scheduling and 
viewer application selection tables 31, 32 are also stored in 
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the data storage device 26 and can be updated by the 
microprocessor 21 . 

A user can make new viewer applications 23-25 
available to the microprocessor 21. To add a new viewer 
application 23-25, the user stores the new application 23-25 
to the data storage device 26 and adds an entry for the new 
application 23-25 in a viewing application selection table 
32. Each entry includes a number of parameters for 
identifying broadcast data that can be processed with the new 
viewer application 23-25. For example, the parameters may 
include a broadcast channel, content provider, and/or content 
form at 

A content provider may make new viewer applications 
available to users, e.g., to support new features of content 
formats being produced by the provider. The new viewer 
applications may be distributed on magnetic or optical disks 
27 in a form readable by a disk reader 28. The new viewer 
applications may also be distributed through an Internet site 
where a user can download the applications or broadcast over 
a satellite, ATSC, or cable network. 

FIG. 3 is a flow chart for a method 40 by which a 
receiver, e.g., a receiver 15-18 of FIGs. 1-2, processes data 
broadcast by a transmitter, e.g., a transmitter 11-13. To 
start processing, a user tunes his or her receiver to a 



10559/055001/P7404 
channel on which a transmitter broadcasts (step 41) . In 
response to the selection, the receiver receives data 
broadcast on the selected channel (step 42) . In response to 
receiving data from the selected channel y^eceiver looks up 
5 schedule information with relevant characteristics for 
identifying the viewer application 23-25 to process the 
scheduled data broadcast (step 44) . These characteristics 
may include the content provider and content format as shown 
in exemplary scheduling table 31. The characteri^s^tics may 
10 also include information on viewer ages, e.g., to stop 
1^ children from seeing portions of some broadcasts. The look 

up includes comparing the actual broadcast time and channel 
with entries of the scheduling table 31, which are indexed by 
channel and time. The look up dynamically associates 
15 relevant characteristics, e.g. the individual content 

%J 

^Jj provider and content format, with each broadcast. 

FIG. 4 shows a portion of one embodiment of the 
scheduling table 31 of FIG. 2. The scheduling table 31 has 
entries 32-35, which are indexed by broadcast time interval 
2 0 and channel in columns A and B, respectively. The entries 32- 
3 5 provide information for identifying one or more viewer 
applications 23-25 for processing a scheduled broadcast. In 
the exemplary table 31, the information includes an identity 
of a content provider and a content format in columns C and D 
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for each broadcast. The content provider is the entity that 
created the broadcast data. Content providers include 
organizations, such as ABC, NBC, CBS, and Disney that produce 
products for broadcast by different transmitters. Content 
5 providers may also include single transmitters, e.g., one of 
the transmitters 11-13, which broadcast data in special local 
formats . 

Referring again to FIG. 3, information from the 
scheduling table 31 enables selections of viewer applications 
10 23-25 adapted to processing the scheduled broadcast data. 

The receiver selects a viewer application 23-25 by using the 
information looked up in the scheduling table 31 as an index 

, ft?: 

ffi for finding entries 51-55 m the viewer application selection 

1^ table 32 (step 46). The entries 51-55 list the viewer 

^ 15 applications 23-25 that are presently available to the 
^L: receiver. 

Each entry of the scheduling table 31 identifies one 
or more entries for viewer applications 23-25 in the viewer 
application selection table 32. Each identified viewer 
20 application 23-25 can process the broadcast data associated 
with the entry in the scheduling table 31. The receiver 15' 
selects a best entry from among the identified entries as 
described below. The receiver 15' decodes and displays the 
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data using the viewer application 23-25 associated with the 
best entry (step 48) . 

FIG. 5 shows a portion of one embodiment of the 
viewer application selection table 32 of FIG. 2. The viewer 
5 application selection table 32 has entries 51-55, which are 
indexed by information relevant to identifying a viewer 
application 23-25. Here, the data includes a broadcast 
channel, a content provider, and a content format in columns 
E, F, and G, respectively. Each entry 51-55 assigns one 
10 viewer application 23-25, in column H, to use to process 
'ph broadcast data described by the information in columns E, F, 

ry 

'^j and G, i.e., scheduling information. 

ru 
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The viewer application selection table 32 of FIG. 5 
1^: is an example of one such table. Other embodiments may 

15 employ viewer application selection tables 32 having other 
types of attribute value pairs in columns E, F, G, H. 

Several entries 51-55 of the viewer application 
selection table may match information from one entry 32-3 5 of 
the scheduling table 31. For example, the entry 33 of the 
2 0 scheduling table 31 has broadcast channel 2, provider ABC, 
and format ATVEF . These broadcast parameters match index 
fields of columns E, F, and G, for the entries 52-54 of the 
viewer application selection table 32. If multiple matches 
occur, the receiver 15' selects the entry that best matches 
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the scheduling information and uses the viewer application 
23-25 associated with that entry to process the broadcast 
data . 

In one embodiment, the best matching entry has more 
5 non-blank index columns than other matching entries of the 
viewer application selection table 32. If no matches occur 
with all non-blank entries, the receiver 15' looks for a 
match with entries having one blank field. The search 
continues to less specific entries if matches are still not 
10 found, i.e., two blank fields, etc. In the above example, 
l^^. the entry 54 is the best match, because this entry 54 has two 

ij non-blank index columns F, G whereas the entries 52-53 only 

have one non-blank column each, i.e., columns F or G. 

3 ts= 

1^ Some receivers assign weights to the columns E-G for 

15 use in determining which entry 51-55 is the best match. For 
^} example, the weights may be 1, 2, and 3 for columns E, F, and 

■^3 G, respectively. Then, an NBC broadcast of ATVEF data on 

channel 8 matches both entries 52 and 55 in the viewer 
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application selection table 32 shown in FIG. 5. But, the 
20 receiver selects the Intel ATVEF viewer applicatioiy, because 
jA^e^/^ the weighty of the column G is higher than/that of oo-lumn 15^ 
^ rt.or^ the entry 52 is the best match. 

The viewer application selection table 32 provides 
multiple matches, because the receivers 15-18 of FIG, 1 have 

- 10 - 
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default applications among the viewer applications 23-25. 
The default applications can process many content formats. 
More specific matches provide viewer applications 23-25 that 
support additional features in broadcast data. For example, 
5 content provider ABC may incorporate special interactive 
features into its ATVEF content. Those features are 
presented to viewer if the receiver 15' processes the ABC 
broadcast data with a Disney General Viewer of entry 54, 
i.e.; a specific match. If the receiver 15' does not have 
s§ 10 the Disney general viewer, the receiver 15' processes ABC 
1^ ATVEF broadcasts with the default Intel ATVEF viewer, i.e., 

\i associated with entry 52. The default viewer may not support 

ry the special interactive features incorporated by ABC. 

FIG. 6 IS a flow chart illustrating a method 60 used 

P 

..Z 15 by a transmitter, e.g., a transmitter 11-13 of FIG. 1, to 
^ broadcast data. The transmitter sends a scheduling message 

"X" to the receivers, e.g., the receivers 15-18 of FIG. 1 (step 

62). The scheduling message provides scheduling information 

for one or more broadcasts, i.e., one or more entries 33-35 
2 0 in the scheduling table 31 shown in FIG. 4. The scheduling 

information may include time interval, channel, content 

provider, and/or content format. 

In response to receiving a scheduling message, a 

receiver updates its scheduling table, e.g., the table 31 of 
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FIG. 2 for the receiver 15. The receiver writes a new entry 
to its scheduling table for each new data broadcast announced 
by a received scheduling message. 

In the network 10, the scheduling messages may also 
be sent over the same medium 20 of FIG. 1 that transports 
data for viewing or over a separate network. The separate 
network may be the Internet or a service information channel 
reserved for sending scheduling messages from the 
transmitters 11-13 to the receivers 15-18. 

The transmitter broadcasts the scheduled data over 
the channel at the time period announced in the previous 
scheduling message (step 64) . The scheduling messages are 
sent sufficiently ahead of data broadcasts to ensure that 
receivers can update their scheduling tables 31 prior to the 
broadcasts . 

Other embodiments are within the scope of the 
following claims. 

What is claimed is: 
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